package com.aura.springbook.config;

import com.aura.springbook.common.interceptor.AdminPermissionInterceptor;
import jakarta.annotation.Resource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * Web配置类
 * 当前主要配置了管理员权限检查拦截器
 */
@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Resource
    private AdminPermissionInterceptor adminPermissionInterceptor;

    /**
     * 添加拦截器
     * <p>
     * 注册管理员权限检查拦截器，拦截所有以/api/admin/开头的请求
     * 确保只有管理员用户才能访问管理员相关接口
     *
     * @param registry 拦截器注册器
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 注册管理员权限检查拦截器
        registry.addInterceptor(adminPermissionInterceptor)
                .addPathPatterns("/api/admin/**");
    }
}